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METHODS AND APPARATUS FOR CONTROLLEsfG 
DEVICES WITHIN STORAGE NETWORKS 

15 

FIELD OF THE INVENTION 

The present invention generally relates to systems for managing data storage, and 
more particularly, to systems and techniques which provide control of various 
heterogeneous devices within a networked data storage environment. 

20 

BACKGROUND OF THE INVENTION 

The vast growth of information service and data processing industries has resulted 
in a need for computer systems to manage and store large amounts of data. As an 
example, financial service businesses such as banks, mutual fimd companies or the like 
25 often operate large and complex data processing systems that require access to many 
hundreds of gigabytes or even terabytes of data. Data storage system developers have 
responded to these types of data storage requirements by integrating large capacity data 
storage systems into networks called "storage networks". 
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As this name implies, a storage network is a collection of data storage systems 
that are networked with each other and with a number of host computer systems that 
operate as servers to serve data stored in the data storage systems. In a typical 
implementation, one or more connectivity devices, such as high speed data switches, 
5 interconnect the various data storage systems to each other and to one or more servers of 
the computer systems (servers) that require access to (e.g., read and/or write) the data in 
the data storage systems. As the servers access (e.g., read and/or write) the data, the data 
switches channel the data access requests (e.g., data read requests, data write requests) to 
the appropriate data storage systems within the storage network. 

1 0 A network management station is also included in a typical data storage network. 

Generally, the network management station manages the servers, data switches, and data 
storage systems the comprise the storage network. To do so, the network management 
station includes management software that can remotely control, manage and configure 
components of the data storage network. By way of example, the management software 

15 can configure allocations of storage network resources (e.g., one or more data storage 
volumes) to specific hosts or groups of host computer systems (e.g., servers or other 
computer systems that require access to data in the storage network). Storage network 
resources that can be managed in this manner include, among other things, disk 
partitions, volume configurations, and access control mechanisms within the data storage 

20 systems and the data switches. In some storage networks, the network management 
station and associated management software allows a network administrator or systems 
manager (a person responsible for managing the storage network) to establish "zones" of 
related resources within the storage network. 

Generally, a zone of resources within a storage network is an association, relation 

25 or grouping of resources (e.g., servers, sMdtch channels, portions of data storage) that are 
arranged according to fiinction or location. By way of example, a network administrator 
can use conventional vendor-supplied (i.e., manufacturer supplied) storage network 
management software to configure a zone of ports (data communications channels or 
paths) within that vendor's data switch to associate certain servers in the data storage 

30 network with certain allocations of data storage within one or more of the data storage 



EMCOO-0 1(000 10) 

-3- 

systems in the data storage network. Thus, the network administrator might, for example, 
define a zone to include a server or group of servers, a dedicated channel through the data 
switch (via allocation of one or more ports), and an amount of data storage space in the 
form of one or more volumes of storage maintained within one or more of the data 
5 storage systems. An administrator might create such a zone in the storage network, for 
example, for each department (e.g., engineering, accounting, human resources, and the 
like) within a company, 

A data switch (one or more) that channels requests for data between the various 
data storage devices and server computer systems is generally responsible for zone 

1 0 enforcement. In operation of a typical data switch, each port within the data switch is 
dedicated to transferring data to and/or from a single respective data storage system or 
server computer system. To create a zone, the management software causes the data 
switch to establish a grouping of one or more server ports (i.e., connections between the 
data switch and a server) with one or more data storage system ports (i.e., connections 

1 5 between the data switch and a data storage system) together into a zone. Generally, 
resources (servers, switch ports, and portions of data storage systems) within the same 
zone can "see" or access each other, while resources in different zones cannot access 
each other. As an example, a server in a first zone can access data storage in the first 
zone, but not data storage allocated to other zones. Thus, zoning in the context of storage 

20 networks operates as a form of access control and provides an organized mechanism of 
managing and associating amounts of data storage to specific computer systems. 

Typically, a network administrator creates a zone of servers and associated 
storage resources for an intended purpose. For example, an administrator might place 
accounting servers and accounting data into an accounting zone, while engineering 

25 servers and engineering data storage resources might be placed into an engineering zone. 

Most manufacturers of storage network equipment (data storage systems and data 
switching equipment to handle data access requests) provide some form of zoning 
capabilities within vendor-supplied management software that is specifically designed to 
manage devices manufactured by that vendor's data storage network equipment product 

30 line. As noted above, most manufactures implement zoning within the data switching 
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equipment as this equipment serves as the central data transfer point to handle the transfer 
of data access requests between server computer systems and the data storage systems 
which store the data. 

5 SUMMARY OF THE INVENTION 

Though zoning is a common characteristic in storage network equipment (e.g., 
data switches) made by different manufacturers, the commands and interfaces used to 
control zoning within a particular manufacturers equipment are often specific to that 
manufacturer. As an example, commands used to control zoning within a data switch for 

10 use in storage networks manufactured by IBM Corporation might differ from commands 
used to control zoning within a data switch for use in storage networks manufactured by 
EMC Corporation. Other data storage network manufactures and vendors such as 
Brocade Communications Incorporated, Hitachi, Mercury Computer Systems, and the 
like might each provide a set of zoning control and configuration commands that differ 

15 from each other. These zoning control commands are typically implemented within 
vendor supplied and vendor specific management software applications. Such 
conventional zoning control and management applications cannot control zoning in 
devices made by other vendors. This may be problematic if a customer desires to use 
storage network equipment made by different manufacturers within the same storage 

20 network. 

For instance, if a customer uses a data switch fi'om IBM Corporation and another 
data switch firom Hitachi Corporation in the same data storage network, various problems 
might arise when that customer attempts to configure zoning within each of these 
different data switches. Each data switch may require that a network administrator 

25 perform zoning configuration and control using zoning commands designed and 
developed by the specific manufacturer of the switch, as implemented within that 
manufacturer's storage network management software. As such, the network 
administrator might be required to operate two different storage network management 
software applications. One storage network management application might be provided 

30 from IBM to provide proper control of zoning in the IBM data switch, and another 
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storage network management application might be provided from Hitachi to properly 
control zoning in the Hitachi data switch. Each network management application might 
have a different user interface and each may operate quite differently from the other. 
Each management application might also require the customer to have knowledge of 
5 different installation and configuration procedures and may require separate payments of 
software licensing fees. Generally, overhead increases if a customer must maintain, learn 
and operate different storage network management applications from different 
manufacturers in order to manage, configure and control different data storage network 
equipment installed in the same data storage network. 

10 The present invention addresses these and other issues concerning the 

incompatibilities and difficulties encountered when a customer desires to use data storage 
networking equipment from different vendors or manufacturers in the same data storage 
network. While the present invention specifically addresses such issues with respect to 
zoning control in a data storage network, the invention is also generally applicable to 

15 overcoming similar issues with respect to the operation of similar features (e.g., access 
control, device management, and so forth) that are present within storage network devices 
from various manufacturers in cases where those features are controlled or configured 
differently from each other. 

More specifically, the present invention provides mechanisms and techniques that 

20 provide a management station which includes a management application that can control 
zoning within devices manufactured or provided from different vendors within a network 
such as a data storage network. The management application can receive a generic zone 
control command from a user to control zoning within a device in the network. The 
management application can then translate the generic zone control command to one or 

25 more vendor specific device zone control commands in a vendor specific device 

command set that is specifically designed to control zoning within devices from that 
vendor/manufacturer. To perform the translation, the management application can 
identify the vendor of one or more devices that are affected by the generic zone control 
command. Based in this identification, the management application can select and load 

30 an appropriate vendor device command set. The generic zone control command may be 
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in a format that is readily compatible with the vendor specific device command in the 
vendor specific device command set. However, if needed, the management application 
can also access a command mapping that maps (i.e., that matches) parameters for the 
generic zone control command(s) to parameters of the vendor specific zone control 
5 commands. Thus translation may include simply calling the vendor specific command 
based on the generic command, or the generic command may be mapped to the vendor 
specific command. 

Once translated, the management application can perform the vendor specific 
device commands to control zoning in devices from that vendor in the network. Vendor 

1 0 specific device command sets may be dynamically linked libraries, for example, which 
can be loaded into memory as needed. A typical device in which zoning can be 
controlled in this manner is a data storage network switch that channels data between 
servers and data storage systems in a data storage network. Since the management 
application can control zoning in devices made by different vendors/manufacturers which 

1 5 are installed in the same network, a system manager does not need to load vendor specific 
management applications onto the management station, nor do they need to learn each 
user interface for each vendor specific management application. 

According to one embodiment of the invention, a method is provided for 
controlling zoning v^thin a device. The method comprises the steps of receiving a 

20 generic zone control command, translating (i.e., either directly calling or mapping and 
then calling) the generic zone control command to at least one vendor specific device 
command of a plurality of vendor specific device commands that respectively control 
zoning in a plurality of different vendor devices, and performing (e.g., executing) the at 
least one vendor device command to control zoning in a device. Since the generic zone 

25 control command is translated to one or more vendor device commands chosen from a 
database of vendor device commands (e.g., vendor command sets) that can control 
zoning in devices from different vendors, the method allows a single mechanism, such as 
a management application that incorporates the method, to be used to control zoning in 
many different devices from many different vendors in the same network, such as a data 

30 storage network. 
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According to another method embodiment of the invention, the step of translating 
includes steps of identifying a vendor of at least one device within the zone 
corresponding to the generic zone control command and selecting a set of vendor specific 
device commands, from the plurality of vendor specific device commands, that 
5 corresponds to the vendor of the device v^thin the zone. The method also includes the 
operation of mapping the generic zone control command to at least one vendor specific 
device command within the set of vendor specific device commands. In this manner, the 
mapping operation can detennine the vendor of a device which is affected by the generic 
zone control command and can choose a vendor specific device command set based on 

1 0 this vendor identification. 

According to another embodiment of the invention, the step of selecting selects 
the set of vendor specific device commands that are specific to a vendor of a device 
within the zone to which the generic zone control command is directed. For example, in 
a management application that uses this method embodiment, if the management 

15 application receives a generic zone control command to control zoning (e.g., to configure 
a port to be included in a zone) in a data network switch manufactured by EMC 
Corporation, the management application can identify EMC as the vendor of the switch 
and can load an appropriate command set (e.g., an EMC supplied dynamically linked 
library of data network switch routines) that can specifically control zoning in the EMC 

20 switch affected by that generic zone control command. Once loaded, the management 
application can map the generic zone control command to one or more EMC specific 
zone control commands within that command set. It is to be generally understood that 
those skilled in the art are familiar with dynamically loading libraries into software 
applications to allow such application to access fimctions or routines within those 

25 libraries. 

In yet another embodiment, the step of identifying includes steps of identifying a 
zone that is affected by the generic zone control command and identifying devices within 
the zone that are affected by the generic zone control command and identifying vendors 
of the devices within the zone that are affected by the generic zone control command. 
30 These operations allow a management application to determine which vendor specific 
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command sets will be required to properly carry out the intended function of the generic 
zone control command. 

In another embodiment, the plurality of vendor specific device commands include 
sets of vendor specific device commands (e.g., commands that are specific to controlling 
5 functions of devices, such as zoning, from a specific vendor). In this embodiment, the 
step of translating includes the steps of selecting a set of vendor specific device 
commands that can control zoning within a device to which the generic zone control 
command is directed and dynamically loading the set of vendor specific device 
commands into a management application to allow the management application to 

1 0 control zoning within the device to which the generic zone control command is directed. 
Since the vendor specific device command sets can be dynamically loaded, for example, 
into a memory system, a management application employing this technique can control 
zoning in hardware added into a network at anytime, even after the management 
application has commenced processing. That is, hardware can be added to a network 

15 anytime as long as the management application is provided with a database or other 
resource containing the vendor specific commands sets to control zoning in the new 
hardware. When zoning control is attempted on the new hardware via the management 
application, the management application can select the proper zoning control commands, 
for example, based on an identification of the vendor of the new hardware. 

20 In an alternative embodiment, the step of translating includes steps of selecting 

the vendor specific device command (one or more), v^thin the set of vendor specific 
device commands, that performs zoning operations in the device to which the generic 
zone control command is directed in accordance with the generic zone control command 
and mapping parameters of the generic zone control command to parameters of the 

25 vendor specific device command(s) to provide the vendor specific device command(s) 
with data required to perform the zoning operations in the device. A command mapping 
or other data structure (e.g., linked list, object or relational database, etc.) may be used to 
indicate how parameters of the generic zone control command(s) properly map to 
parameters of vendor specific zone control command(s). 



EMCOO-OI(OOOIO) 

-9- 

In yet another embodiment, the step of receiving receives the generic zone control 
command from a device management application that can control zoning in a network of 
devices from different vendors. Since devices from different vendors may be 
incorporated into the same network and zoning in these devices may be managed by the 
5 management application provided by this invention, there is no need to use management 
applications provided for each specific vendor of each specific device to control zoning. 
This saves significant learning time on behalf of a network administrator or a systems 
manager since that person need not learn specific vendor management application 
software interfaces. 

10 In another alternative embodiment, the step of performing performs the vendor 

specific device command to control zoning within a device from a vendor that is a vendor 
of devices that are controlled by the specific vendor specific device command to which 
the generic zone control command is translated. That is, vendor specific zone control 
commands provided from a vendor of the device affected by the generic zone control 

1 5 command are used to control zoning. 

In still another embodiment, the step of translating includes the step of loading a 
library of vendor specific device commands into a management application based on a 
vendor of a device affected by the generic zone control command to allow the 
management application to perform vendor specific device conunands in order to carry 

20 out the generic zone control conmiand within the device affected by the zoned control 
command. 

In another method embodiment, the steps of receiving, translating and performing 
are processed by a management application that controls zoning within devices in a data 
storage network. In this embodiment, the step of translating includes a step of loading a 
25 dynamically linked library of vendor specific device commands, selected based on a 

vendor of a device affected by the zoning control command, into a memory for use by the 
management application to control zoning in the device. 

The present invention also provides other embodiments which include a computer 
system configured to control zoning in a plurality of devices from different vendors in a 
30 network. In such embodiments, the computer system comprises an input-output 
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interface, a processor and a memory system coupled to the processor and to the input- 
output interface and encoded with instructions that form a multi-zone management 
application. When the multi-zone management application is performed on the processor 
(e.g., executes, interprets or otherwise processes), it causes the computer system to 
5 receive, via the input-output interface, a generic zone control command and to translate 
the generic zone control command to at least one vendor specific device command of a 
plurality of vendor specific device commands (e.g., selected from a library via a 
command mapping) that respectively control zoning in a plurality of different vendor 
devices coupled to the input-output interface. The computer system also performs, via 

10 the multi-zone management application in the memory system, the vendor specific device 
command(s) to control zoning in a device coupled to the input-output interface. In other 
words, once the generic zone control command is translated to one or more vendor 
specific commands, the management application performs the vendor specific commands 
to control zoning in devices made by the vendor who supplied to vendor specific 

15 commands. In an alternative embodiment, the computer system also includes a multi- 
zone command database containing the plurality of vendor specific device commands and 
command mappings which can be loaded into the memory system upon identification of 
specific vendors of devices to which generic zone control commands are directed. 

According to other embodiments of the invention, the processor performs (e.g., 

20 executes, interprets or otherwise processes) instructions, code or logic (e.g., a software 
module, library, program, or the like) that is encoded into the memory system to provide 
all of the operations disclosed in the method embodiments (i.e., steps, operations) and 
configurations summarized above and as explained herein. 

Other embodiments include a computer system configured as a management 

25 station to perform all of the aforementioned methods via software control, or via 
hardware and/or software configured to perform those methods and the techniques 
disclosed herein as the invention. 

Other embodiments of the invention that are disclosed herein include software 
programs to perform the operations summarized above and disclosed in detail below. 

30 More particularly, a computer program product is disclosed which has a computer- 
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readable medium including computer program logic encoded thereon to provide the 
methods for controlling zoning within a device according to this invention and its 
associated operations. The computer program logic, when executed on at least one 
processor within a computing system, causes the processor to perform the operations 
5 (e.g., the method embodiments above, and described in detail later) indicated herein. 
This arrangement of the invention is typically provided as software on a computer 
readable medium such as an optical medium (e.g., CD-ROM), floppy or hard disk or 
other such medium such as firmware in one or more ROM or RAM or PROM chips or as 
an Application Specific Integrated Circuit (ASIC). The software or firmware or other 

1 0 such configurations can be installed onto a computer system to cause the computer 
system to perform the techniques explained herein as the invention. 

It is to be understood that the system of the invention can be embodied strictly as 
a software program, as software and hardware, or as hardware alone. Is also to be 
understood that the management application of this invention typically performs (e.g., 

15 executes, runs, or is otherwise operated) on a management station coupled to a data 

storage or other type of network. The management station is generally networked but is 
typically a dedicated computer system, personal computer or workstation operated by a 
network or systems administrator or manager. In alternative arrangements however, the 
management application of this invention may reside on a computer system located 

20 elsewhere on the network and the user (e.g., systems manager) that provides the generic 
zone control commands may be located elsewhere on the network and may be 
conmiunicating with the management station over a network connection (e.g., WWW or 
other browser-type interface, command-line interface, messaging interface, E-Mail, or 
another protocol or interface). Moreover, the multi-zone command database may be local 

25 to, or remotely located from the management station and may be any type of database or 
storage mechanism that can store data. 

An example implementation of the invention that incorporates certain of the 
aforementioned embodiments is the Enterprise Control Center (ECC) software 
management application manufactured by EMC Corporation of Hopkinton, 

30 Massachusetts which can control devices in data storage networks. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The foregoing and other objects, features and advantages of the invention will be 
apparent from the following more particular description of preferred embodiments of the 
invention, as illustrated in the accompanying drawings in which like reference characters 
refer to the same parts throughout the different views. The drawings are not necessarily 
to scale, with emphasis instead being placed upon illustrating the embodiments, 
principles and concepts of the invention. 

Figure 1 illustrates an example of a data storage network and computing system 
environment that is suitable for use in describing example operations of a management 
station configured with a software management application in accordance v^ith 
embodiments of the invention. 

Figure 2 illustrates an example interface between the multi-zone management 
application of this invention and a vendor specific device, which is a data storage 
network switch in this example. 

Figure 3 illustrates an example software architecture of the multi-zone 
management application as implemented within a management station configured in 
accordance with this invention. 

Figure 4 is a flow chart of high-level processing steps showing operations 
performed by embodiments of this invention. 

Figure 5 is an example of a command mapping which maps generic zone control 
commands to vendor device specific zone control commands according to an example 
embodiment of this invention. 

Figure 6 is a flow chart of processing steps showing in more detailed the 
operations performed by embodiments of this invention. 

DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS 

The present invention provides techniques and mechanisms that allow a systems 
manager (person responsible for management and control of computing systems and/or 
other components) to control and configure different devices produced by different 
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manufacturers that co-exist and operate together within a single data storage network. In 
particular, the invention allows a single network management application (e.g., software 
program) to control zoning in various data storage network devices such as switches that 
each might require a different command set or a different application programming 
interface (API) for zoning control. 

Generally, a management application configured with this invention provides a 
generic set of data storage network administration zoning control commands for selection 
and use by the systems manager. When the systems manager selects a generic zoning 
control command, such as "ADD STORAGE DEVICE XYZ TO ZONE 1," the system of 
the invention can determine what devices (e.g., what switch(s) in the network) are (or 
will be) specifically required or involved to perform this zoning command. Once this is 
determined, the management application can access the appropriate vendor-specific 
command set(s) that will allow this zoning command to be carried out within the specific 
devices (e.g., vendor switches). The vendor-specific command sets can be dynamically 
linked libraries, for example, that provide functionality to control zoning in a specific 
vendor switch in the storage network. The management application loads the appropriate 
vendor specific command set(s) and performs the generic zone control command using 
any required corresponding vendor specific command(s) contained within the vendor- 
specific command set. 

It may be the case that the generic zone control command is identical in nature to 
a command in the vendor specific command set, in which case the generic zone control 
command essentially is the same command with the vendor specific command set. In an 
alternative case, the invention may need to map, translate or otherwise convert the 
generic zone control command to one or more vendor specific commands (e.g., map 
parameters of generic command to parameters of vendor specific command). Since the 
management application provides generic zone control commands that correspond to 
zone control commands in each manufacturers command set, zoning control can be 
implemented in a standard fashion irrespective of the specific zoning control application 
programming interfaces required for each device from each different device manufacturer 
or vendor. 
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Moreover, in the case where the generic zone control commands are the same as 
(i.e., are in the same format with the same command name, parameters, etc.) the vendor 
specific commands, no mapping is needed and the management appHcation can simply 
load the required vendor specific command set and call commands within this set (via the 
5 generic commands that are the same) to carry out zone control operations. No mapping 
of commands may be needed in this case. In cases where there may be difference in the 
generic and vendor zone control commands and a mapping is needed, the invention may 
provide the mapping ahead of time as a "wrapper" to the vendor specific command set 
that serves to translate the generic zone control commands to vendor specific commands. 

1 0 Alternatively, the mapping of such commands may be done in real-time. 

Figure 1 illustrates an example of a data storage network 100 in which the present 
invention operates. Generally, the data storage network 100 includes servers 140, 142 
and 144, data storage network switches 120, 122 and a plurality of data storage systems 
150 through 156. Also included are arrangements of network hosts 130, 132 and 350. 

1 5 Host 350 operates as a network management station and performs (e.g., executes) a 

multi-zone management application 300 that accesses multi-zone command database 310. 
A systems manager operates the network management station 350 via the multi-zone 
management application 300 to configure and control zoning within, for example, the 
data storage network switches 120, 122. Since switches 120, 122 operate to couple 

20 servers 140 through 144 to data storage devices 150 through 156, zoning within the 

switches 120 and 122 essentially allows ports (not specifically shown in this figure) in the 
switch that couple the servers and data storage systems to be grouped together in zones. 
Thus zoning is primarily carried out by the switches 120, 122. 

In this particular example, the data storage network 100 is configured into three 

25 zones (zone-1 , zone-2, zone-3). As noted above, the zones in this example are essentially 
groupings of ports v^thin the switches 120, 122. Zone-1 includes the zone-1 hosts 130, 
the zone-1 server 140, and the zone-1 data storage systems 154. Zone-2 includes the 
zone-2 hosts 132, the zone-2 server 142, and the zone-2 data storage systems 150 and 
156, Zone-3 includes the zone-3 host 350 (i.e., the network management station in this 

30 example), the zone-3 server 144, and the zone-3 data storage systems 152. The data 
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storage network switches 12.0, 122 are configured to support and enforce the zones within 
the data storage network 100. 

Of particular importance to this example embodiment of the invention is that 
different vendors or manufacturers produce the various switches 120, 122 (as well as 

5 other devices) installed within this example data storage network 1 00 . In other words, 
the data storage network 100 is a composition of various heterogeneous components that 
may each operate or be controlled somewhat differently from each other. For instance, 
data storage network switches 120, 122 are manufactured by vendors A and B 
respectively. Each vendor-specific switch 120, 122 may require the use of vendor- 

1 0 specific command set(s) to control and configure zoning with that switch. 

In contrast to this invention, in a conventional data storage network (not shown 
here), a vendor may provide a vendor specific network management application that 
includes an appropriate command set to control zoning within that vendor's switches. If 
a conventional data storage network were to use switches from multiple vendors, a 

1 5 systems manager would be required to operate multiple management applications (one 
for each different vendor) to manage zones in each switch since each different vendor 
switch requires the use of vendor specific zone control commands to manipulate zoning 
within that vendors' devices. In other words, conventional or prior art zoning control 
requires the use of vendor specific management applications equipped to exclusively 

20 operate with only the vendor specific commands associated with sv^tches manufactured 
from that vendor and do not allow control of, for instance, zoning in many different 
switches from many different vendors. 

Conversely, the multi-zone management application 300 configured with 
embodiments of this invention allows a systems manager, using this single multi-zone 

25 management application 300 (equipped with components on the invention), to control 
and configure zoning within the data storage network switches 120, 122 in the data 
storage network 100, irrespective of which vendor produces or provides such switches. 
This is accomplished, as will be detailed below, since the multi-zone management 
application 300 has access to multi-zone command database 310. 
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Multi-zone command database 310 includes vendor specific command sets to 
control zoning within switches produced or provided from specific vendors. As will be 
explained further, the multi-zone management application 300 of this invention presents a 
single set of generic zone control commands to the systems manager via the management 
5 station 350. Upon selection ofa generic zone control command, the multi-zone 

management application 300 performs or carries-out the generic zone control command 
within a specific vendor switch using one or more vendor specific device zone control 
commands obtained from the multi-zone command database 310. 

Figure 1 thus illustrates the power which is inherently provided by the system of 
1 0 the invention to allow a network designer (e.g., systems manager) to design a network 
using components such as switches from different vendors without regard to maintaining 
separate management applications. In particular, a systems manager may initially create 
a data storage network (e.g., 100) using, for example, a data storage switch from vendor- 
A (e.g., switch 120), and then, at a later time may decide to purchase a data storage 
1 5 switches firom another vendor (e.g., vendor-B data storage switch(s) 1 22) and incorporate 
these switches into the same data storage network. The invention thus avoids the 
problem of a network manager having to learn how to operate a second network 
management application to administer zoning in the switches from another vendor. To 
implement data storage network services such as zoning, which may vary in operation, 
20 control and configuration from vendor to vendor, the invention saves significant time and 
eliminates the need to modify the network management application with the addition of 
new vendor switches to the network. 

Figure 2 illustrates in more detail the interaction between the multi-zone 
management application 300 and the vendor specific data storage network switches 120 
25 and 122. Figure 2 illustrates vendor-B's data storage switch 122 in detail. The 

configuration and operation of vendor-A's data storage switch 120 is similar except that 
Vendor A's switch 120, as will be explained, requires functionality provided by Vendor- 
A's device command set 320-1 while Vendor-B's switch 122 requires functionality 
provided by Vendor-B's device command set 320-2. 
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In this example configuration, the multi-zone management application 300 
includes vendor specific device command set application programming interfaces(APIs) 
320-1, 320-2 which communicate via interfaces 210-1 and 210-2 with respective vendor 
switches 120, 122 which each include vendor switch application programming interfaces 
5 (APIs) 322-1 and 322-2. The respective interface pairs 320-1, 322-1 (between the 
application 300 and the vendor-A switch 120) and 320-2 and 322-2 (between the 
application 300 and the vendor-B switch 122) operate according to zoning commands 
sets, interfaces, and/or protocols specified and/or required by the specific vendors (A and 
B in this example) of the switches 120, 122. In this particular configuration, the vendor 

10 specific device command set APIs 320-1 and 320-2 comprise vendor specific device 
commands and functionality that control zoning in respective switches 120, 122 
manufactured or supplied by the vendors that provide the APIs 320-1 and 320-2. Actual 
command syntax and/or parameters (e.g., formats of function calls) to zoning control 
commands within each vendor specific command set 320-1 and 320-2 might be the same 

1 5 (or similar, as will be explained) but the underlying functionality required to manipulate 
the individual vendor switches 120, 122 might vary from vendor to vendor. In other 
words, the function calls to control zoning from vendor to vendor might be the same or 
similar, but they way each vendor goes about implementing those zoning operations 
within that vendor's switch 120, 122 might be different, hence the need for separate 

20 vendor specific device command sets 320-1 , 320-2. 

The multi-zone management application 300 using this invention obtains the 
vendor specific device command set APIs 320 from the multi-zone command database 
310 which stores a plurality of vendor specific device command sets 320 for the various 
vendors corresponding to switches (in this example) in the data storage network 100. 

25 The vendor specific device command set APIs 320 may be dynamically linked libraries 
(dlls), for example, which include functions, routines or procedures which the multi-zone 
management application 300 can perform to configure and control zoning in the 
respective vendor devices, such as vendor switches 120,122, as shown in this example. 
Figure 2 also illustrates how zoning may be implemented within a particular 

30 vendor switch (122 shown in detail in this example). As noted in the background section 
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above, a typical data storage, network switch includes a plurality of ports to which servers 
and data storage systems (and possibly other devices) can connect. In this example, the 
switch 122 includes server ports 180-1 through 180-N and data storage ports 190-1 
through 190-N. The ports 180 and 190 are coupled via a switch fabric 195. The vendor- 
5 specific switch API 322-2 within the switch 122, under direction of vendor specific 
commands from the vendor-B device command set 320-2, can control the switch fabric 
195 to configure which ports (both server ports and data storage ports) are allocated to 
which zones. In other words, by pairing server ports 180 and data storage ports 190 with 
each other to form a zone, servers and data storage systems connected to those ports are 

10 thereby inherently allocated or included in that zone. By way of example, server port 
180-1 is dedicated or allocated to zone-1 and handles the transfer of data to and from the 
zone-1 server 140 (Figure 1) via interface 160-1. Likewise, data storage port 190-1 is 
also allocated or included in zone-1 (due to control by vendor switch API 322-2) and 
handles, via the interface 170-1, the transfer of data to and from data storage systems 154 

1 5 which are also in zone- 1 . 

While this example illustrates a one-to-one mapping between server ports 180 and 
data storage ports 190 to form a zone, it should be understood that many-to-one mappings 
also possible. For example, a single server port 180 which couples a server (e.g., 142, 
Figure 1) that serves many hosts (e.g., zone-2 hosts 132) may be "zoned" to muhiple data 

20 storage ports 190 within the same data storage switch 122. The vendor specific switch 
API 322-2 controls the zoning association of ports (one or more server ports 180 paired 
with one or more data storage ports 190 to form a zone) based on the vendor specific 
commands received from the vendor specific device command set API 320-2 over 
interfaces 210-2. 

25 In this embodiment, the vendor specific device command set APIs 320 can be 

dynamically loaded as needed by the multi-zone management appUcation 300. As will be 
explained further, the multi-zone management application 300 is able to identify a vendor 
of a switch (e.g., is able to determine that EMC Corporation manufactures switch 122) 
within a zone corresponding to a generic zone control command. In a preferred 

30 embodiment, the systems manager selects a generic zone control command (not shown) 
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in the multi-zone management application 300 which specifies a zone, particular devices 
or resources within a zone, and a manner in which the devices or other resources in that 
zone are to be configured or controlled. The management application 300 can then 
properly select (i.e. load in the case of a dll), based on the vendor of the switch, the 
5 proper set of vendor specific device commands that provide the vendor device control 
API 320 (320-2 for the EMC switch 122) based on the identity of the vendor of the 
specified device(s) or resources. Thereafter, generic zone control commands given to the 
management application equipped with the invention can be performed using the vendor 
specific conmiands within the selected (i.e., loaded) vendor specific command set. 

10 Figure 3 illustrates an example software architecture implemented within a 

management station 350 configured with the invention. The management station 350 
includes an input/output interface 330, a processor 352, a device identifier 315 and a 
memory system 354. The memory system 354 is encoded with a multi-zone management 
application user interface 300-1, a multi-vendor application programming interface 300- 

15 2, and groups of mappings 300-3 through 300-M. These components are incorporated 
into the multi-zone management application 300. The mappings 300 further include 
switch mappings 300-3, data storage mappings 300-4, server mappings 300-5, and other 
mappings 300-M. By way of example, the set of switch mappings 300-3 contains any 
required vendor specific command mappings (330-1 in this example) that map or 

20 translate (as will be explained) parameters of the generic zone control commands 360 
directed to the IBM switch 120 to parameters of the specific IBM device zone control 
commands 365-1 . Also shown in this figure are the vendor specific device commands 
sets 320-1 through 320-P. With respect to zoning control, vendor specific device 
command sets 320-1 and 320-2, as explained above, contain the vendor device specific 

25 commands 365 to control zoning in particular vendor switches within the data storage 
network 100. The management station 350 also contains a coupling to the multi-zone 
command database 310 which maintains copies of the vendor specific device commands 
sets 320-1 through 320-P (only a 320-1 through 320-3 shovm due to drawing space 
limitations). 
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It is to be understood that while the preferred embodiments of this invention relate 
to zoning control within different vendor switches in a data storage network, Fig. 3 and 
the invention as a whole for that matter are meant to be general in nature such that other 
vendor specific functionality or services beside zoning (e.g. device discovery, by way of 
5 example only) are supported by the generic control commands provided by a 
management application equipped with this invention. That is, while the specific 
implementations described here operate to control zoning in different vendor device, the 
same concepts can be applied to other mappings 300-4, 300-5, 300-M (if required, as will 
be explained) and other vendor command sets 320-3 through 320-P in Fig. 3, Such other 

10 vendor command sets 320-3 through 320-P can be used by the system of the invention in 
a similar manner as the zoning command sets 320-1, 320-2 to allow generic control 
commands to control other services or fijnctionality (beside zoning, which is primarily 
done within switches), such as discovery for example, which are performed in 
conjunction with other vendor devices besides switches. Accordingly, generic commands 

15 360 for other services may be performed by the invention using mappings 300-4 through 
300-M (if required) and vendor specific command sets 320-3 through 320-P to produce 
vendor specific commands 365-3 (for specific vendor data storage systems), 365-4 (for 
specific vendor servers), and 365-Q (for any other vendor devices). The operation of the 
management station 350 illustrated in Figure 3 with respect to zoning control only will 

20 now be discussed in conjunction with the high-level flow chart of processing steps shown 
in Figure 4. 

In operation of the management station 350, a user (e.g., systems manager, not 
specifically shovm) selects generic zone control commands 360 (e.g., to configure zones 
within switches) via the input/output interface 340, The multi-zone management 
25 application user interface 300-1, which is preferably a graphical user interface, provides a 
set of generic zone control commands (not specifically shown, but referenced in the 
figure generally as 360) to allow a systems manager to control zoning with the various 
switches 120, 122 in the data storage network 100 (Figure 1). When a user selects a 
generic zone control command 360, the multi-zoned management application user 
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interface 300-1 receives the zone control command 360 (Step 400, Figure 4) for further 
processing. 

As previously explained, zoning allows a systems manager to group various 
resources (e.g., devices coupled to switches) together to allow those resources to access 
5 each other through a switch while at the same time disallowing access to those resources 
from devices or other resources not included in the zone. Examples of typical zone 
control commands 360 include "ADD" to add a resource (e.g., storage space, switch port, 
server) to a zone, "REMOVE" to remove a resource from a zone, "DELETE" to delete a 
zone entirely and "CONFIGURE" to otherwise configure a zone in a particular manner. 
10 Zone control commands, whether they be generic or specific to a device, typically 

include one or more parameters which specify, for instance, a resource associated with 
the zone (e.g., data storage system to be added, removed, or otherwise configured within 
the zone). 

In step 400, the multi-zone management application user interface 300-1 receives 

15 and passes the generic zone control command 360 to the multi-vendor application 

programming interface 300-2. In step 401, the multi-zone management application 300 
loads the appropriate set of vendor specific commands (320-1 or 320-2 in this example), 
as selected from a group of command sets from different vendors. Once the proper 
vendor specific command set 320 is loaded, in step 402, the management application 300 

20 performs or processes (i.e., executes) the generic zone control command within the 
appropriate vendor's switch (either 120, 122 in this example). 

In one embodiment, to do so, the multi-vendor application programming interface 
300-2 uses the device identifier 315 to identify a vendor of the switch(s) that is/are 
affected by the generic zone control command 360. This may be done, for example, by a 

25 device identifier table (not shown) within the device identifier 315 that matches switch 
identities (i.e., network addresses) with vendor identities. An entry in such a device 
identifier table might indicate, for example, that the data storage network switch 120 
(Figure 2) is manufactured by IBM Corporation. Another entry may indicate that the 
data storage network switch 122 (Figure 2) is manufactured by EMC Corporation. Based 

30 on the identification of a vendor in response to receipt of a zone control command 360, 
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the multi-vendor application programming interface 300-2 then sends a load command 
set signal 385 to the multi-zone command database 3 10 in order to obtain the appropriate 
specific set of vendor specific device commands 320 that the multi-zone management 
application 300 can use to specifically control zoning within the switch(s) identified as 
5 being affected by the zone control command 360. In response to this command, the 
multi-zone command database 310 returns the vendor specific device command set 320 
for the specified (i.e., identified) switch/vendor and places/loads the command set(s) 320 
into the memory system 354. As noted above, the vendor specific device command sets 
320 which are loaded into memory 354 in this manner may be dynamically linked 

10 libraries, for example, which the multi-vendor application programming interface 300-2 
can dynamically link into to obtain access to the proper functions, routines, procedures 
and/or the like in order to control zoning in a specific vendor device. 

In a preferred operation of the invention, function calls to zoning control 
fimctions within the vendor specific command sets 320 are of the same name, syntax 

1 5 and/or parameter formats as the generic zone control commands 360 to which those 
vendor specific fiinctions correspond. In such cases, no special switch command 
mappings 300-3 are required since the generic zone control commands 360 are the same 
format as zoning commands 365 used by the switch vendors. This is illustrated in Fig 3 
by the arrow passing uninterrupted fi^om the multi -vendor API 300-2 through the switch 

20 mappings 330-3 to the EMC vendor specific command set 320-2. In other words, EMC 
specific commands to control zoning follow the same conventions, format and syntax as 
the generic zone control commands and thus no command mappings 330 are needed. 

However, in some instances, there may be differences between the name, syntax, 
parameter placement and/or parameter values of one or more generic zone control 

25 commands 360 and the zone control fimction (or fiinctions) 365 vdthin the vendor 

specific device command sets 320 that are executed to carry out the generic zone control 
commands within a specific vendor switch. In such cases, a command map 330 is 
required to map or translate the generic zone control command 360 to a format 
acceptable by the vendor specific command sets 320. 
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The system of the invention may include one or more command mappings 330 
which describe how to map or pass generic zone control command (e.g., 360) function 
names, parameters and/or their associated values to one or more vendor device specific 
command (e.g., 365) names, parameters and/or parameters values as required for the 
5 vendor specific commands in the vendor specific device command set(s) 320. 

Figure 5 illustrates an example of a specific command mapping 330, which maps 
generic zone control commands 360 to vendor device specific zone control commands 
365-1 for IBM commands 365-1. Both IBM and EMC commands 365-1 and 365-2 are 
shown in this example mapping 330 however to illustrate how EMC zone control 
10 commands 365-2 of the same format as generic command 360 do not need to be 
specifically mapped, while IBM zone control commands 365-1 do require such a 
mapping. 

In this example command mapping 330, only three generic zone control 
commands (create-zone, add-to-zone and remove-zone) are shown. It is to be understood 

1 5 that a typical command mapping 330 can contain a mapping for each generic zone 

control command 360 provided by the user interface 300-1 to corresponding commands 
for one or more vendors (e.g., IBM and/or EMC, etc). The generic CREATE ZONE 
command includes a ZONE parameter, a SERVERS parameter and a 
DATA_STORAGE_ RESOURCE parameter. This particular generic zone control 

20 command 360-1 is used to create a zone within a switch (e.g., within switch 120 or 122) 
by including a server and some data storage in the zone. Note that the EMC zone control 
command for this same function and the other all appear identical to the generic zone 
control commands 360. As such EMC commands need no mapping. Thus, if a 
management application using this invention receives a generic zone control command 

25 360 (e.g., CREATE-ZONE) and determines that the sv^tch to which this command is 
directed is an EMC switch, the system can simply load the EMC dll containing the EMC 
functionality to control zoning in EMC switches and can forward the generic zone control 
command to the EMC command set 320-2. 

In the case of IBM zoning control commands however, the command mapping 

30 330 serves to map or translate the generic zone control command 360 into the 
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corresponding IBM zone control command 365-1. In the case of the CREATE ZONE 
command, the generic parameter SERVERS is mapped to the IBM specific SERVER ID 
parameter, and the generic parameter DATA_STORAGE_RESOURCE is mapped to the 
IBM specific parameter DATA STORAGE ID. Other generic zone control commands 
5 360 are mapped to corresponding IBM zoning commands 365-1 in a similar manner. The 
command mapping 330 thus allows the system of the invention, during operation, to 
convert generic commands 360 into vendor specific commands 365 within the vendor 
specific command sets (IBM command set 320-1 for the IBM mapping 330-1 in this 
example) if needed. Note that the example illustration in Figure 3 includes an IBM 

10 command mapping 330-1 (loaded into memory upon receipt of a generic zone control 
command directed to an IBM switch, for example) but no mapping for generic zone 
control commands 360 that are issued to the EMC specific command set 320-2 (i.e., to 
control an EMC switch) since the EMC commands 365-2, as explained above, 
correspond exactly in format to the generic zone control commands 360. 

15 If command mappings 330 are required, a software developer (i.e., either a vendor 

or the developer of the management application 300) may create and install such 
command mappings 330 into the multi-zone command data database 310 before 
operation of the management application 300. Alternatively, the management application 
300 may create the command mappings 330 in real-time using, for example, hard-coded 

20 knowledge or other logic indicating which parameters of a generic zone control command 
correspond 360 map to which parameters of a specific vendor specific device command 
365. 

Since the system of the invention provides the systems manager with a set of 
generic zone control commands 360, the systems manager need not install any vendor 

25 specific systems management applications that are conventionally used to control zoning 
in the vendor specific devices (switches in the case of zoning) installed into the data 
storage network 100. The systems manager only needs to obtain and install the 
dynamically linked library or other vendor specific command set 320 (e.g., a vendor 
supplied dll) into the multi-zone command database 310. Once the systems manager has 

30 installed the vendor commands sets 320-1 through 320-P into the command database 310, 
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the multi-zone management application 300 of the present invention can access these 
functions as explained above to control devices (e.g., control zoning in switches) from 
many different vendors installed within a single data storage network. As such, the 
systems manager only needs to learn the multi-zone management application user 
5 interface 300-1 of the management application 300, instead of learning many user 

interfaces provided by different management applications according to each vendor. As 
new devices such as a new vendor switch are added to the network, as long as the vendor 
specific command set 320 for that sv^tch is loaded into the database 310 (along with any 
mapping 330, if required), then the system of the invention can access and control zoning 

1 0 in that switch without modification to the management application 300. 

Figure 6 illustrates a series of processing steps 404 through 410 which explain in 
more detail an example of processing performed by embodiments of the invention. Steps 
404 through 410 are typically embodied as software code within the memory system 354 
of Figure 3. During operation of embodiments of the invention, the processor 352 within 

15 management station 350 performs (e.g., executes, runs, interprets) this code (e.g., logic 
instructions). It is to be understood that any type of software development platform can 
be used to create the multi-zone management application 300 embodied by these steps. 
Examples of such software development platforms include C-H-, C, Java, and the like. 
After receipt of a generic zone control command 360 (Step 400, Figure 4), the 

20 management application 300, in step 404 in Figure 6, identifies any zone management 
devices (e.g., IBM switch 120) within the zone that are (i.e., that will be) affected by the 
zoned control command 360. Next, in step 405 the management application 300 
identifies vendors (e.g., IBM) of the zone management devices identified in step 404. 
Based on this identification, in step 406, the management application 300 selects an 

25 appropriate set or sets of vendor specific device commands (e.g., the IBM command set 
320-1) that can properly control zoning within the zone management device (IBM switch 
120) to which the generic zone control command is directed. In step 407, the 
management application 300 dynamically loads the set of vendor specific device 
commands (i.e., loads the IBM dll 320-1, and mapping 330-1 if present in database 3 10) 

30 into the multi-zone management application 300 (e.g., into memory 354). Next, in step 
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408, the management application 300 selects one or more vendor specific device 
commands (e.g., CREATE ZONE) in the set of loaded vendor specific device commands 
(e.g., 320-1) that correspond to, and perform the zoning operations in the zone 
management device(s) (e.g., switch 120) to which the generic zone control command 360 
5 is directed, in accordance with the generic zone control command 360. 

In the case of IBM zone control commands, in step 408, the management 
application 300 determines that the mapping 330-1 is present (i.e., was loaded in step 
407) and thus proceeds to step 409. In step 409, the management application consults the 
appropriate conmiand mapping 330-1 to map the generic zone control command to a 

10 vendor specific command (i.e., to an IBM zone control command). As noted above, 
generally, in step 409, the management application 300 maps any parameters from the 
generic zone control command 360 to parameters in the vendor specific device 
commands 365 to provide the vendor specific device command 365 with any data 
required to properly perform zoning operations in the vendor specific device (e.g., within 

15 the switch). 

If no mapping is required (e.g., in the case of EMC commands which are identical 
to generic zone control commands), no command map 330 is present in memory 354 and 
thus the management application 300 in step 408 can proceed directly to step 410. 

In step 410, the management application 300 performs the vendor specific device 

20 command(s) 365 (using the parameters obtained in step 409 from the mapping, or 
obtained directly form the generic zone control command) to carry out the intended 
zoning operation within the vendor specific svritch. 

In this manner, the management application 300 is able to dynamically detect 
devices such as switches from different vendors within a data storage network (e.g., 100) 

25 and is able to control zoning within each of those switches using a single consistent 

multi-zone management application user interface 300-1. By determining the identity of 
vendors of switches to which generic zone control commands 360 are directed, the 
management application 300 of this invention can dynamically load the appropriate 
vendor specific command sets (e.g., 320-1, 320-2) and command maps 330 (if required) 

30 to control zoning within any vendor devices without requiring the systems manager to 
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use a separate management application to perform zoning operations in each different 
vendor device. The invention thus also allows a network designer to incorporate 
hardware for many different vendors within a data storage network without having to 
worry about zoning control compatibility issues. 
5 While the example explanations of preferred embodiments presented herein relate 

to controlling zoning within vendor devices in a data storage network, it is to be 
understood by those skilled in the art that the mechanisms and techniques of this 
invention are applicable for control of other types of vendor specific operations (e.g., 
discovery) within devices installed within a network. For example, the management 

1 0 application 300 might carry out operations such as device power up, device 

configuration, port control, discovery, or other such operations that require specific 
vendor libraries of vendor specific control commands by providing an interface of 
generic commands for such operations which are then mapped to the vendor specific 
commands within the vendor-specific libraries that perform the operations in a 

1 5 corresponding vendor specific device. 

Those skilled in the art will understand that there can be many variations made to 
the operations of the user interface explained above while still achieving the same 
objectives of the invention. Such variations are intended to be covered by the scope of 
this invention. As such, the foregoing description of embodiments of the invention are 

20 not intended to be limiting. Rather, any limitations to embodiments of the invention are 
presented in the following claims. 
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CLAIMS 



What is claimed is: 



5 LA method for controlling zoning within a device, the method comprising the steps of: 
receiving a generic zone control command; 

translating the generic zone control command to at least one vendor specific 
device command of a plurality of vendor specific device commands that respectively 
control zoning in a plurality of different vendor devices; and 
10 performing functions associated with the at least one vendor specific device 

command to control zoning in a device. 

2. The method of claim 1 wherein the step of translating includes the steps of: 

identifying a vendor of at least one device within a zone corresponding to the 
15 generic zone control command; and 

selecting a set of vendor specific device commands, from the plurality of vendor 
specific device commands that respectively control zoning in devices from different 
vendors, that corresponds to the vendor of at least one device within the zone. 

20 3. The method of claim 2 wherein the step of selecting a set of vendor specific device 
commands selects the set of vendor specific device commands that are specific to a 
vendor of a device that exists within the zone to which the generic zone control command 
is directed. 



25 4, The method of claim 2 wherein the step of identifying includes the steps of: 

identifying devices within the zone that are affected by the generic zone control 
command; and 

identifying vendors of the devices within the zone that are affected by the generic 
zone control command. 



30 
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5. The method of claim 1 wherein: 

the plurality of vendor specific device commands include sets of vendor specific 
device commands; and 
5 wherein the step of translating includes the steps of: 

selecting a set of vendor specific device commands that can control 
zoning within a device to which the generic zone control command is 
directed; and 

dynamically loading the set of vendor specific device commands 
10 into a management application to allow the management application to 

control zoning v^thin the device to which the generic zone control 
command is directed. 

6. The method of claim 5 wherein the step of translating includes steps of: 

15 selecting the at least one vendor specific device command, within the set of 

vendor specific device commands, that performs zoning operations, in the device to 
which the generic zone control command is directed, in accordance with the generic zone 
control command; and 

mapping parameters of the generic zone control command to parameters of the at 

20 least one vendor specific device command to provide the vendor specific device 
command with data required to perform the zoning operations in the device. 

7. The method of claim 5 wherein the set of vendor specific device commands is selected 
based on an identity of a vendor of the device to which the generic zone control 

25 command is directed. 

8. The method of claim 1 wherein the step of receiving receives the generic zone control 
command from a device management application that can control zoning in a network of 
devices manufactured by different vendors. 
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9. The method of claim 1 wherein the step of performing performs the at least one 
vendor specific device command to control zoning within a device from a vendor that is a 
vendor of devices that are controlled by the vendor specific device command to which the 
generic zone control command is translated. 

5 

10. The method of claim 1 wherein the step of translating includes the steps of: 

loading a library of vendor specific device commands into a management 
application based on an identity of a vendor of a device affected by the generic zone 
control command; and 

10 calling the at least one vendor specific device command using the generic zone 

control command having the same format as the at least one vendor specific device 
command perform zoning operations within the device affected by the generic zone 
control command. 



15 11. The method of claim 1 wherein the steps of receiving, translating and performing are 
processed by a management application that controls zoning within switches in a data 
storage network and wherein the step of translating includes a step of loading a 
dynamically linked library of vendor specific device commands, selected based on a 
vendor of a device affected by the generic zone control command, into a memory for use 

20 by the management application to control zoning in the device. 



25 



30 



EMCOO-OI(OOOIO) 



-31- 



12. A computer system configured to control zoning in a plurality of devices from 
different vendors in a network, the computer system comprising: 

an input-output interface; 
a processor; and 

5 a memory system coupled to the processor and to the input-output interface and 

encoded with instructions that form a multi-zone management application that, when 
performed on the processor, cause the computer system to: 

receive, via the input-output interface, a generic zone control command; 
translate the generic zone control conamand to at least one vendor specific 
10 device command of a plurality of vendor specific device conamands that 

respectively control zoning in a plurality of different vendor devices coupled to 
the input-output interface; and 

perform the at least one vendor device specific command to control zoning 
in a device coupled to the input-output interface. 

15 

13. The computer system of claim 12 further including: 

a multi-zone command database containing the plurality of vendor specific device 
commands; and 

wherein the multi-zone management application encoded within the memory 
20 system includes instructions that, when performed on the processor, cause the computer 
system to: 

identify a vendor of at least one device within the zone 
corresponding to the generic zone control command; 

select a set of vendor specific device commands, from the plurality 
25 of vendor specific device commands in the multi-zone command database, 

that corresponds to the vendor of at least one device within the zone; and 

map the generic zone control command to at least one vendor 
specific device command within the set of vendor specific device 
conunands. 



30 



EMCOO-OI(OOOIO) 



-32- 



14. The computer system of claim 13 wherein the instructions that select, when 
performed on the processor, cause the computer system to select the set of vendor 
specific device commands that are specific to a vendor of a device within the zone to 
which the generic zone control command is directed. 

5 

15. The computer system of claim 13 wherein the instructions that identify, when 
performed on the processor, cause of the computer system to: 

identify devices within the zone that are affected by the generic zone control 
command; and 

10 identify vendors of the devices within the zone that are affected by the generic 

zone control command. 



16. The computer system of claim 12 wherein: 

the plurality of vendor specific device commands within the multi-zone command 
1 5 database include sets of vendor specific device commands; and 

wherein the instructions that translate, when performed on the processor, cause 
the computer system to: 

select a set of vendor specific device commands that can control 
zoning within a device to which the generic zone control command is 
20 directed; and 

dynamically load the set of vendor specific device commands into 
the memory system to allow the management application to control zoning 
within the device to which the generic zone control command is directed. 
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17. The computer system of claim 16, wherein the instructions that translate, when 
performed on the processor, cause the computer system to: 

select the at least one vendor specific device command, within the set of vendor 
specific device commands, that performs zoning operations, in the device to which the 
5 generic zone control conunand is directed, in accordance with the generic zone control 
conmiand; and 

map parameters of the generic zone control command to parameters of the at least 
one vendor specific device command to provide the vendor specific device command 
with data required to perform the zoning operations in the device. 

10 

1 8. The computer system of claim 16 wherein the instructions that select the set of 
vendor specific device commands, when executed, cause the computer system to select 
the set of the vendor specific device commands based on an identity of a vendor of the 
device to which the generic zone control conamand is directed. 

15 

19- The computer system of claim 12 wherein the multi-zone management application is 
a device management application that can control zoning in a network of switches from 
different vendors, the network coupled to the input-output interface. 

20 20. The computer system of claim 12 wherein the instructions that perform, when 

performed on the processor, cause the computer system to perform the at least one vendor 
specific device command to control zoning within a device firom a vendor that is a vendor 
of devices that are controlled by the vendor specific device command to which the 
generic zone control command is mapped. 
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21. The computer system of claim 12 wherein the instructions that translate, when 
performed on the processor, cause the computer system to load a library of vendor 
specific device commands into a management application based on a vendor of a device 
affected by the generic zone control command to allow the management application to 

5 perform vendor specific device commands in order to carry out the generic zone control 
command within the device affected by the generic zone control command. 

22. The computer system of claim 12 wherein the instructions that translate, when 
performed on the processor, cause the computer system to load a dynamically linked 

10 library of vendor specific device commands, selected by a device identifier coupled to the 
memory system, based on a vendor of a device affected by the zoning control command, 
into the memory system for use by the management application to control zoning in the 
device. 

15 23. The computer system of claim 12 wherein the memory system is encoded with at 
least one command mapping that indicates how the generic zone control command 
corresponds to the vendor specific device command for a specific vendor device, and 
wherein the instructions that translate use the command mapping to map the generic zone 
control command to a format required by the vendor device specific command within the 

20 vendor device specific command set. 
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24. A computer program product having a computer-readable medium including 
computer program logic encoded thereon that when performed on a computer system 
provides a method for controlling zoning within a device, and wherein when the 
computer program logic is performed on a processor in the computer system, the 
computer program logic causes the processor to perform the operations of: 

receiving a generic zone control command; 

translating the generic zone control command to at least one vendor specific 
device command of a plurality of vendor specific device commands that respectively 
control zoning in a plurality of different vendor devices; and 

performing the at least one vendor specific device command to control zoning in a 

device. 

25. The computer program product of claim 24 wherein the plurality of vendor specific 
device commands includes sets of vendor specific device commands and wherein the 
computer program logic that causes the processor to perform the operation of translating, 
when performed on the processor, causes the processor to perform a operations of: 

selecting a set of vendor specific device commands that can control zoning within 
a device to which the generic zone control command is directed; and 

dynamically loading the set of vendor specific device commands into a 
management application to allow the management application to control zoning within 
the device to which the generic zone control command is directed. 
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26. The computer program product of claim 24 wherein the computer program logic that, 
when performed on the processor, causes the processor to perform the operation of 
translating, further includes instructions that, when performed on the processor, cause the 

5 processor to perform the operations of; 

selecting the at least one vendor specific device command, within the set of 
vendor specific device commands, that performs zoning operations, in the device to 
which the generic zone control command is directed, in accordance with the generic zone 
control command; and 

10 mapping parameters of the generic zone control command to parameters of the at 

least one vendor specific device command to provide the vendor specific device 
command with data required to perform zoning operations in the device. 

27. A management application that operates to control zoning in devices from different 
15 vendors in a data storage network, the management application comprising: 

a management application user interface that receives a generic zone control 
command; 

a multi-vendor application programming interface coupled to the multi-zone 
management application user interface, the multi-vendor application programming 
20 interface obtaining firom a multi-zone command database, based on the generic zone 
control command, a vendor specific command set containing functions that control 
zoning in a device associated with the generic zone control command; 

a command mapping accessible by the multi- vendor application programming 
interface, the command mapping defining mappings between parameters from the generic 
25 zone control command to parameters required by the vendor specific commands within 
the vendor specific command set; and 

the multi-vendor application programming interface using the command mapping 
to map the generic zone control command to at least one vendor specific command and 
performing the at least one vendor specific command to control zoning within a specific 
30 vendor device associated with the generic zone control command. 
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METHODS AND APPARATUS FOR CONTROLLING 
DEVICES WITHIN STORAGE NETWORKS 

5 ABSTRACT OF THE DISCLOSURE 

Mechanisms and techniques provide a management station which includes a 
management application that can control zoning within devices manufactured or provided 
from different vendors within a network, such as a data storage network. The 

10 management application can receive a generic zone control command from a user to 
control zoning within a device in the network. The management application translates 
the zone control command to one or more vendor specific device zone control commands 
in a vendor specific device command set that is specifically designed to control zoning 
within devices from a specific vendor. To perform the translation, the management 

1 5 application can identify the vendor of one or more devices that are affected by the zone 
control command. Based in this identification, the management application can select an 
appropriate vendor specific device command set that contains vendor specific zone 
control commands. The generic zone control command can then either be used as a call 
directly into the vendor specific command set if the vendor specific command is the same 

20 format as the generic zone control command, or, the generic zone control command can 
be mapped using a command mapping to the vendor specific device command. Once 
mapped, the management application can perform the vendor specific device commands 
to control zoning in the devices in the network. Vendor specific device command sets 
may be dynamically linked libraries which can be loaded into memory as needed. A 

25 typical device in which zoning can be controlled in this manner is a data storage network 
switch that channels data between servers and/or data storage systems in a data storage 
network. 



130 

ZONE-1 HOST(S) 




140 
ZONE-1 
VENDOR-A 
SERVER(S) 



1 



iliiiiiiiaini 



132 

ZONE-2 HOST(S) 




142 
ZONE-2 
VENDOR-B 
SERVER(S) 



niiiinniiiiiii 



160 



120 
VENDOR-A 
SWITCH(S) 



350 

ZONE-3 HOST(S) 
(E.G. MANAGEMENT 
STATION) 



310 
MULTI-ZONE 
COMMAND DATA 



300 
MULTI-ZONE 
MANAGEMENT 
APPLICATION 



144 
ZONE-3 
VENDOR -C 
SERVER(S) 



iiiiniiiiiiiiM 



122 
VENDOR-B 
SWITCH(S) 




FIG. 1 



300 


MULTI-ZONE 


MANAGEMENT APPLICATION 




320-1 


320-2 






VENDOR-A 


VENDOR-B 






DEVICE 


DEVICE 






COMMAND SET 


COMMAND SET 






A.P.I. (E.G., IBM) 


A.P.I.(E.G., EMC) 






4— ► 



310 
MULTI-ZONE 
COMMAND DATA 



210-1- 



-210-2 



120 
VENDOR-A 
SWITCH(S) (E.G., IBM) 



322-1 



122 

VENDOR-B SWITCH (E.G., EMC CONNECTRIX) 



TO/FROM TO/FROM 
ZONE-1 ZONE-2 
SERVER(S) SERVER(S) 



TO/FROM 
ZONE-N 
SERVER(S) 



1 60-1-^ 160-2-^ 1 60-N-^ 



170-1 



170-2^ 170-N-^ 



TO/FROM 
ZONE-1 
DATA 
STORAGE 



TO/FROM 
ZONE-2 
DATA 
STORAGE 



TO/FROM 
ZONE-N 

DATA 
STORAGE 



180-1 


180-2 




180-N 






ZONE-1 


ZONE-2 




ZONE-N 






SERVER 


SERVER 


■ ■ ■ 


SERVER 






PORT(S) 


PORT(S) 




PORT(S) 






i 




i 










r 






322-2 


195^ 












VENDOR-B 












SWITCH 


^ 


r 




r 




r 


A.P.I. 


190-1 


190-2 




190-N 






ZONE-1 


ZONE-2 




ZONE-N 






DATA 


DATA 


m m m 


DATA 






STORAGE 


STORAGE 




STORAGE 






PORT(S) 


PORT(S) 




PORT(S) 







FIG. 2 



360 
GENERIC 

ZONE 
CONTROL 
COMMANDS X 
(E.G., ADD, 
REMOVE, 
DELETE, 
CONFIGURE) 



385 
LOAD 
COMMAND 
SET SIGNAL 



320, 330 
VENDOR 
COMMAND 
SETS 
AND 
MAPPINGS 



350 

MANAGEMENT STATION 



340 

INPUT/OUTPUT 
INTERFACE 



352 
PROCESSOR 



1 



315 
DEVICE 
IDENTIFIER 



354 MEMORY 



300-1 

MULTI-ZONE MANAGEMENT APPLICATION USER 
A INTERFACE 



300-2 

MULTI-VENDOR APPLICATION PROGRAMMING 
INTERFACE 



300-3 
SWITCH 
MAPP- 
INGS 



330-1 



320-1 
IBM 



320-2 
EMC 



300-4 1 

DATA 
STORAGE 
MAPPINGS 



320-3 



300-5 ^ 
SERVER 
MAPPINGS 



320-4 



300 



OTHER 
MAPPING 



320-P 



t t 1 

365-3 365-4 365-Q 




260 



310 

MULTI-ZONE COMMAND DATA 



320-1 IBM. DLL 



320-2 EMC.DLL 



320-3 BROCADE.DLL 



1 



365-1 
VENDOR-A 
DEVICE 
SPECIFIC 
COMMANDS TO 
SWITCH 120 
(E.G., IBM ZONING 
CONTROL) 



365-2 
VENDOR-B 
DEVICE 
SPECIFIC 
COMMANDS TO 
SWITCH 122 
(E.G., EMC ZONING 
CONTROL) 



FIG. 3 



400 

RECEIVE GENERIC ZONE CONTROL COMMAND 



1 


r 


401 

LOAD APPROPRIATE VENDOR DEVICE COMMAND SET SELECTED FROM 
COMMAND SETS FOR DIFFERENT VENDORS 




r 


402 

PERFORM VENDOR DEVICE COMMAND(S) TO CONTROL ZONING IN 
DEVICE(S) IN ACCORDANCE WITH GENERIC ZONE CONTROL COMMAND 



FIG. 4 



330 



360 

GENERIC ZONE CONTROL 
COMMANDS 


365-1 
IBM ZONE 
CONTROL COMMANDS 


365-2 

EMC ZONE CONTROL 
COMMANDS 


CREATE_ZONE{ZONE, 
SERVERS, 
DATA_STORAGE_RESOURCE) 


CREATE_ZONE{ZONE, 
SERVER ID, 
DATA_STORAGE_ID) 


CREATE ZONE(ZONE, 
SERVERS, 
DATA_STORAGE_RESOURCE) 


ADD TO ZONE(ZONE, 
RESOURCE) 


ADD TO ZONE(ZONE, 
PORT) 


ADD TO ZONE(ZONE, 
RESOURCE) 


REMOVE ZONE(ZONE, 
RESOURCE) 


REMOVE ZONE(ZONE, 
PORT) 


REMOVE ZONE(ZONE, 
RESOURCE) 



FIG. 5 



404 

IDENTIFY ZONE MANAGEMENT DEVICE(S) AFFECTED BY THE ZONE 

CONTROL COMMAND 



405 

IDENTIFY VENDOR(S) OF ZONE MANAGEMENT DEVICE(S) 



1 

406 

SELECT A SET OF VENDOR SPECIFIC DEVICE COMMAND(S) THAT CAN CONTROL 
ZONING WITHIN THE ZONE MANAGEMENT DEVICE{S) 



t 

407 

DYNAMICALLY LOAD THE SET OF VENDOR SPECIFIC DEVICE 
COMMANDS INTO THE MULTI-ZONE MANAGEMENT APPLICATION 



408 

SELECT VENDOR SPECIFIC DEVICE COMMAND(S) IN THE SET OF LOADED 

VENDOR SPECIFIC DEVICE COMMANDS THAT PERFORM ZONING 
OPERATIONS IN THE ZONE MANAGEMENT DEVICES IN ACCORDANCE WITH 
THE GENERIC ZONE CONTROL COMMAND 



MAPPING REQUIRED 



409 

MAP THE GENERIC ZONE CONTROL 
COMMAND THE VENDOR SPECIFIC 
DEVICE COMMAND(S) 



NO MAPPING REQUIRED 



410 

PERFORM THE VENDOR DEVICE COMMAND USING THE PARAMETERS TO 
CARRY OUT THE INTENDED ZONING OPERATION IN THE VENDOR DEVICE 



FIG. 6 



DOCKET NO. EMCOO-OUOOOlO) 



IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 
Declaration for Patent Application 

As a named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated next to my name; 

I believe I am the original, first and sole inventor (if only one name is listed) or an original, first and joint 
mventor (if plural names are listed in the signatory page(s) commencing at page 3 hereof) of the subject matter which 
is claimed and for which a patent is sought on the invention entitled 

METHODS AND APPARATUS FOR CONTROLLING DEVICES WITHIN STORAGE 
NETWORKS 

the specification of which (check one) 
[ X ] is attached hereto. 

[ ] was filed on as United States Application 

Number or PCX International Application No. 



and was amended on (if applicable). 

I hereby state that I have reviewed and understand the contents of the above-identified specification, 
including the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is known by me to be material to patentability as 
defined in 37 C.F.R. §1.56. 

I hereby claim foreign priority benefits under 35 U.S.C. 1 19(a)-(d) or 365(b) of any foreign application(s) 
for patent or inventor's certificate or 365(a) of any PCX international application which designated at least one 
country other than the United States of America, listed below and have also identified below, by checking the box, 
any foreign application for patent or inventor's certificate, or of any PCX international application having a filing 
date before that of the application on which priority is claimed: 

Prior Foreign Application(s) Priority Certified 

Not Copy Filed? 

Clahned YES NO 

[ ] [ ] [ ] 
[ ] [ ] [ ] 
[ ] [ ] [ ] 



(Number) 


(Country) 


(Day/Month/Year filed) 


(Number) 


(Country) 


(Day/Month/Year filed) 


(Number) 


(Countiy) 


(Day/MonthA'ear filed) 



I hereby claim the benefit under 35 U.S.C. §1 19(e) of any United States provisional application(s) listed below. 



(Application Number) (Filing Date) 



(Application Number) 



(Filing Date) 



-2- 



DOCKET NO, EMCOO-OUOOQIO) 



I hereby claim the benefit under 35 U.S.C. 120 of any United States application(s), or 365(c) of any PCT 
international application designating the United States of America, listed below and, insofar as the subject matter of 
each of the claims of this application is not disclosed in the prior United States or PCT International application in 
the manner provided by the first paragraph of 35 U.S.C. 1 12, 1 acknowledge the duty to disclose information known 
by me to be material to patentability as defined in 37 C.F.R. 1.56 which became available between the filing date of 
the prior application and the national or PCT mtemational filing date of this application: 



(Application Serial No.) 



(Filing date) 



(Status: patented, pending, abandoned) 



(Application Serial No.) 



(Filing date) 



(Status: patented, pending, abandoned) 



(Application Serial No.) 



(Filing date) 



(Status: patented, pending, abandoned) 



(Application Serial No.) 



(Filing date) 



(Status: patented, pending, abandoned) 



As a named inventor, I hereby appoint the following attomey(s) and/or agent(s) to prosecute this application 
and transact all business in the Patent and Trademark Office connected therewith. 

I also hereby grant additional Powers of Attorney to the following attomey(s) and/or agent(s) to file and 
prosecute an international application under the Patent Cooperation Treaty based upon the above-identified 
application, including a power to meet all designated office requirements for designated states: 



John M. Gunther, Reg. No. 26,175 
Leanne J. Fitzgerald, Reg. No. 40,606 
William R. Clark, Reg. No. 29,523 
Krishnendu Gupta, Reg. No. 37,977 



Barry W. Chapin, Reg. No. 39,934 
David E. Huang, Reg. No. 39,229 
J. Scott Southworth, Reg. No. 39,382 
Penelope Wilson, Reg. No. 29,751 



all of Chapin & Huang, L.L.C., Westborough Office Park, 1700 West Park Drive, Westborough, MA 01581 

and EMC Corporation. 171 South Street Hopkinton. MA 01748 

to prosecute this application and to transact all business in the Patent and Trademark Office connected therewith. 

Please send correspondence to: Barry W. Chapin, Esq. 



Chapin & Huang. L.L.C. Westborough Office Park. 1700 West Park Drive, Westborough. MA 01581 

Direct telephone calls to: Barry W. Chapin, Esq. Telephone No.: 508-366-9600 

Direct facsimiles to: Barry W. Chapin, Esq. Facsimile No.: 508-616-9805 

I hereby declare that all statements made herein of my own knowledge are true and that all statements made 
on information and belief are believed to be true; and further that these statements were made with the knowledge 
that willful false statements and the like so made are punishable by fme or imprisonment, or both, under Section 
1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the 
application or any patent issued thereon. 



Full name of sole 

or first inventor Ale >aDubrovskv s i 

Inventor's Signature ^^^^ g | W 1 eo 

Residence v^48 Thomas Newton Drive 

Westborough, Massachusetts 01581 

Citizenship Israeli 

Post Office Address Same as above 



-3- 



DOCKET NO. EMCOQ-OUOOOlO) 



Full name of second j oint ' 

Inventor Haim Kirshenberg # 

Inventor's Signature ' x ^ Date ^/ U I 

Residence 4 Alton Ct. 

Brookline, Massachusetts 02446 

Citizenship Israeli 

Post Office Address Same as above 



Full name of third joint 
Inventor Par S. Efroni 



Inventor's Signature ^'^^^^^^fC^ 6 ; ^ Date _ 

Residence 358 Cedar Street 

Ashland. Massachusetts 01721 

Citizenship Israeli 

Post Office Address Same as above 



Full name of fourth joint 



Inventor 



Q jff Steven M. Blumenau 



Inventor*s Signature, 
Residence 



Date 



170 Holly Lane 



Citizenship _ 



Post Office Address 



Holliston. Massachusetts 01746 



United States of America 



Same as above 



